查看原文
其他

HTTP 304 ?

欢迎关注👉 程序员升级打怪 2023-02-06

大家都知道 304 代表内容没有变,可以直接用缓存。

但具体流程是怎么样的呢?服务端和客户端(例如:浏览器)是怎么交互的呢?服务端怎么知道内容没有变化(每个客户端请求内容可能不一样),直接返回 304 呢?

今天就来学习下这知识点。

Last-Modified/If-Modified-Since

通常服务器知道你所请求的数据的最后修改时间,并且 HTTP 为服务器提供了一种将最近修改数据连同你请求的数据一同发送的方法。

如果你第二次 (或第三次,或第四次) 请求相同的数据,你可以告诉服务器你上一次获得的最后修改日期:在你的请求中发送一个 If-Modified-Since 头信息,它包含了上一次从服务器获得数据所获得的时间。

如果数据从那时起没有改变,服务器将返回一个特殊的 HTTP 状态代码 304,这意味着 “从上一次请求后这个数据没有改变”。

这一点有何进步呢?当服务器发送状态编码 304 时,不再重新发送数据,仅仅获得了这个状态码。

所以当数据没有更新时,你不需要一次又一次地下载相同的数据,服务器假定你有本地的缓存数据。

所有现代的浏览器都支持最近修改 (last-modified) 的数据检查。

如果你曾经访问过某页,一天后重新访问相同的页时发现它没有变化,并奇怪第二次访问时页面加载得如此之快——这就是原因所在。

你的浏览器首次访问时会在本地缓存页面内容,当你第二次访问,浏览器自动发送首次访问时从服务器获得的最近修改日期。服务器简单地返回 304: Not Modified,因此浏览器就会知道从本地缓存加载页面。

ETag/If-None-Match

ETag 是实现与最近修改数据检查同样的功能的另一种方法:没有变化时不重新下载数据。

其工作方式是:服务器发送你所请求的数据的同时,发送某种数据的 hash (在 ETag 头信息中给出),hash 的确定完全取决于服务器。

当第二次请求相同的数据时,你需要在 If-None-Match 头信息中包含 ETag hash,如果数据没有改变,服务器将返回 304 状态码。

与最近修改数据检查相同,服务器仅仅 发送304 状态代码;第二次将不为你发送相同的数据。在第二次请求时,通过包含 ETag hash,你告诉服务器:如果 hash 仍旧匹配就没有必要重新发送相同的数据,因为你还有上一次访问过的数据。

好了,全文完,今天你学到了吗?

天进步一点点,离大厂进一点点

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存